# # This script was written by David Maciejak # # Ref: Lostmon # # This script is released under the GNU GPLv2 # if(description) { script_id(15717); script_bugtraq_id(11587); if ( defined_func("script_xref") ) script_xref(name:"OSVDB", value:"11624"); script_version ("$Revision: 1.2 $"); name["english"] = "Goollery XSS"; script_name(english:name["english"]); desc["english"] = " Goollery, a GMail based photo gallery written in PHP, is installed on this remote host. According to it's version number, this host is vulnerable to a cross-site-scripting (XSS) attack threw viewpic.php script. An attacker, exploiting this flaw, would need to be able to coerce a user to browse to a purposefully malicious URI. Upon successful exploitation, the attacker would be able to run code within the web-browser in the security context of the remote server. Solution : Upgrade to Goollery 0.04b or newer Risk factor : Medium"; script_description(english:desc["english"]); summary["english"] = "Checks for the presence of Goollery XSS flaw in viewpic.php "; script_summary(english:summary["english"]); script_category(ACT_GATHER_INFO); script_copyright(english:"This script is Copyright (C) 2004 David Maciejak"); family["english"] = "CGI abuses : XSS"; script_family(english:family["english"]); script_dependencie("cross_site_scripting.nasl"); script_require_ports("Services/www", 80); exit(0); } # # The script code starts here # include("http_func.inc"); include("http_keepalive.inc"); port = get_http_port(default:80); if ( get_kb_item("www/" + port + "/generic_xss") ) exit(0); if(!get_port_state(port)) exit(0); if(!can_host_php(port:port)) exit(0); function check(loc) { req = http_get(item:string(loc, "/viewpic.php?id=7&conversation_id=&btopage=0"), port:port); r = http_keepalive_send_recv(port:port, data:req, bodyonly:1); if( r == NULL ) exit(0); if(egrep(pattern:"", string:r)) { security_warning(port); exit(0); } } dir = make_list(cgi_dirs(),"/goollery"); foreach d (dir) { check(loc:d); }